草庐IT

python - 如何在python中解析google-blogger中的xml文件?

全部标签

Ruby - 如何在 Prawn 中使用不同的字体?

我有一个小的Ruby程序,我在其中使用Prawn将一些文本打印成PDF,但一小部分文本是非英文字符。(其中一些文本是中文,一些是希腊文,等等)。当我运行我的程序时,我当然会收到一条错误消息,提示您的文档包含与Windows-1252字符集不兼容的文本。(Prawn::错误::IncompatibleStringEncoding)如果您需要完整的UTF-8支持,请使用TTF字体而不是PDF的内置字体。我知道我需要使用TTF字体,但我该怎么做呢?我需要从网上安装吗?如果是这样,我应该把它保存到哪里?我知道这可能是一个愚蠢的问题,但我是Ruby和Prawn的新手。谢谢!

ruby - 我如何在 Ruby 中解构一个范围?

是否可以在ruby​​中使用解构来提取范围的结束和开始?modulePriceHelperdefprice_range_human(range)"$%sto$%s"%[range.begin,range.end].map(:number_to_currency)endend我知道我可以使用数组强制作为一个非常糟糕的hack:first,*center,last=*rng"$%sto$%s"%[first,last].map(:number_to_currency)但是有没有一种语法方法可以在不实际手动创建数组的情况下获取begin和end?min,max=(1..10)会很棒。

ruby - 如何在 ruby​​ 中使用反引号开始子进程的连续输出

我有一个ruby​​应用程序,它使用反引号将ant作为子进程执行。这没有任何问题。当我执行putant时,ruby等待子进程ant完全完成,然后将输出打印到标准输出。如何让ruby​​连续打印子进程的输出? 最佳答案 你可以使用IO.popen。IO.popen("ant")do|output|whileline=output.getsdo#...maybeputsline?somethingmoreinteresting?endend 关于ruby-如何在ruby​​中使用反引号开始子

ruby - 如何在 ruby​​ 中拆分字符串并在拆分中维护空格

我有一个字符串:"hello\tWorld\nbla"我想把它拆分成:["hello\t","World\n","bla"]我如何在Ruby中执行此操作? 最佳答案 >>"hello\tWorld\nbla".scan/\S+\s*/=>["hello\t","World\n","bla"] 关于ruby-如何在ruby​​中拆分字符串并在拆分中维护空格,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com

ruby-on-rails - 了解 Rails 中的简单 ActiveRecord 更新

我刚刚深入研究ActiveRecord,但未能找到我的问题的答案。如果我正在更新对象的属性然后调用save()...ActiveRecord是否仅在新值与旧值不同时才保存到数据库?假设我做了这样的事情:thing_to_update=Thing.find_or_create_by_code(some_code)ifthing_to_update.name!=some_namething_to_update.update_attribute(:name,some_name)end如果不需要的话,我不想对数据库进行额外的调用,因为我可能不得不更新很多对象。我试图通读文档,但它没有提及任何关

ruby-on-rails - Ruby on Rails 私有(private)链接共享 : Google Docs Style

如果要让用户能够共享一个私有(private)链接,让任何点击它的人都能查看具有隐私限制的特定页面/文档/项目,最好的方法是什么?以我为例:用户创建的事件仅限于数据库中某些关系组(即:friend、friend的friend等)我在事件Controller中有一个:before_filter检查资格当前登录用户的权限,以确保该用户有权查看该事件。如果他们不这样做,他们将被引导到根页面并显示一条错误消息。但是,我希望存在一个特殊场景,用户可以使用相同的隐私设置创建一个事件,此外,还可以通过电子邮件、Facebook等方式与他或她的friend分享一个特殊链接。那些用户不需要帐户(但需要创

ruby - 如何在 Ruby 中有效地解析大文本文件

我正在编写一个导入脚本来处理一个可能有数十万行的文件(日志文件)。使用一个非常简单的方法(如下)占用了足够的时间和内存,我觉得它随时都会耗尽我的MBP,所以我终止了这个过程。#...File.open(file,'r')do|f|f.each_linedo|line|#dostuffheretolineendend这个文件特别有642,868行:$wc-lnginx.log/code/src/myimport642868../nginx.log有谁知道处理此文件中每一行的更有效(内存/cpu)方法吗?更新上面f.each_line中的代码只是将正则表达式与该行进行匹配。如果匹配失败,我

ruby-on-rails - 用 Prawn 生成 PDF - 如何访问 Prawn.generate 中的变量?

我正在尝试使用Prawn生成pdf@buyer=Buyer.lastPrawn::Document.generate("samle.pdf")dotext"hello#{@buyer.name}world"end但这显然不起作用(仅当我使用类变量@@buyer时),我的问题是将变量传递给Prawn::Document.generate的正确方法是什么(我知道这个问题的解决方案是prawnto,但我正在尝试一些......而且它也是一个sinatra项目) 最佳答案 来自http://rdoc.info/github/sandal/p

ruby - 如何在 ruby​​ 中使用 getoptlong 类?

我需要有关在Ruby中使用getoptlong类的帮助。我需要执行命令prog_name.ruby-u-i-s文件名。到目前为止,我只能使用prog_name.ruby-u文件名-i文件名-s文件名来执行它。这是我的getoptlong代码:require'getoptlong'classCommonLogparser=GetoptLong.newparser.set_options(["-h","--help",GetoptLong::NO_ARGUMENT],["-u","--url",GetoptLong::NO_ARGUMENT],["-i","--ip",GetoptLong

ruby - 如何将 Ruby 哈希 "up"中的属性移动一级

x={:name=>"John",:data=>{:physical=>{:age=>25,:weight=>150}}}我希望将数据的子属性向上移动一个级别(但不一定只是简单地展平所有属性)。在这种情况下,我基本上想将:physical属性“向上”移动一个级别。我正在尝试这个y=x[:data']y.each{|key|x[key]=y[key]}但是我得到...x=x.except(:data)=>{:name=>"John",[:physical,{:age=>25,:weight=>150}]=>nil}我在找...=>{:name=>"John",:physical=>{:a